home *** CD-ROM | disk | FTP | other *** search
/ Workbench Add-On / Workbench Add-On - Volume 1.iso / BBS-Archive / DiskUtil / Crunch / XFH.lha / XFH / SRC / GUI.C < prev    next >
C/C++ Source or Header  |  1994-04-11  |  6KB  |  198 lines

  1. /* gui.h - interface to the XFH GUI control panel by Nicola Salmoria.
  2.    Adapted from example code by Nicola Salmoria.
  3.    Copyright (C) 1991, 1992, 1993 Kristian Nielsen.
  4.  
  5.    This file is part of XFH, the compressing file system handler.
  6.  
  7.    This program is free software; you can redistribute it and/or modify
  8.    it under the terms of the GNU General Public License as published by
  9.    the Free Software Foundation; either version 2 of the License, or
  10.    (at your option) any later version.
  11.  
  12.    This program is distributed in the hope that it will be useful,
  13.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  14.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  15.    GNU General Public License for more details.
  16.  
  17.    You should have received a copy of the GNU General Public License
  18.    along with this program; if not, write to the Free Software
  19.    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.            */
  20.  
  21. #include "CFS.h"
  22.  
  23. #include <exec/ports.h>
  24. #include <exec/semaphores.h>
  25. #include <exec/memory.h>
  26. #include <exec/execbase.h>
  27.  
  28. #include <string.h>
  29. #include <stdlib.h>
  30.  
  31. #include <dossupport.h>
  32.  
  33. #include "gui.h"
  34.  
  35. #define GUISIGMASK SIGBREAKF_CTRL_F
  36. #define MAX_PACK_MODE 100
  37.  
  38. extern struct ExecBase *SysBase;
  39.  
  40.  
  41. /* KS1.3 support hack to fix bug in AddSemaphore(). */
  42. static void MyAddSemaphore(struct SignalSemaphore *sem){
  43.   if(SysBase->LibNode.lib_Version >= 36){
  44.     debug(("Calling KS2.0 AddSemaphore().\n"));
  45.     AddSemaphore(sem);
  46.   }else{
  47.     debug(("Using KS1.3-style AddSemaphore().\n"));
  48.     sem->ss_Link.ln_Type=NT_SIGNALSEM;
  49.     InitSemaphore(sem);
  50.     Forbid();
  51.     Enqueue(&SysBase->SemaphoreList,&sem->ss_Link);
  52.     Permit();
  53.   }
  54. }
  55.  
  56. /* Lock the semaphore and return a pointer to it, or NULL if it isn't there. */
  57. /* If it can't find it, will try to create a new one; so this function will */
  58. /* fail only due to severe low memory conditions */
  59. /* When done with the list, the semaphore must be freed with ReleaseSemaphore() */
  60.  
  61. /* You shouldn't need to call this function directly, let UpdateXFHNode() do that for you */
  62. static struct XFHSemaphore *GetSemaphore(glb glob){
  63.   struct XFHSemaphore *sem;
  64.   static UBYTE xfhsemaphorename[] = XFHSEMAPHORENAME;
  65.  
  66.   Forbid();
  67.   if(!(sem = (struct XFHSemaphore *)FindSemaphore(xfhsemaphorename)) &&
  68.     (sem = AllocMem(sizeof(struct XFHSemaphore) + sizeof(XFHSEMAPHORENAME)
  69.           + 1,MEMF_CLEAR | MEMF_PUBLIC))){
  70.     debug(("Creating new semaphore.\n"));
  71.     sem->xfh_Length = sizeof(struct XFHSemaphore);
  72.     sem->xfh_Semaphore.ss_Link.ln_Name = ((UBYTE *)(sem + 1));
  73.     strcpy(sem->xfh_Semaphore.ss_Link.ln_Name,xfhsemaphorename);
  74.     NewList(&sem->xfh_DeviceList);
  75.     MyAddSemaphore((struct SignalSemaphore *)sem);
  76.   }
  77.   Permit();
  78.  
  79.   /* out of Forbid() because the semaphore is guaranteed not to be removed */
  80.   if(sem){
  81.     debug(("Locking semaphore...\n"));
  82.     ObtainSemaphore((struct SignalSemaphore *)sem);
  83.   }else{
  84.     debug(("ERROR: No memory for new semaphore!\n"));
  85.     OUTOFMEM;
  86.   }
  87.   return(sem);
  88. }
  89.  
  90. #define bool2string(b) ( (b) ? "YES" : "NO" )
  91.  
  92. static BOOL ReadConfigSem(glb glob, struct XFHNode *node){
  93.   char buf[256];
  94.   
  95.   SPrintF(buf,"STEPDOWN=%s",bool2string(node->xfh_LowMemory));
  96.   set_option(glob, buf);
  97.   
  98.   if(node->xfh_AutoPack && node->xfh_PackerID){
  99.     set_option(glob, "AUTOCOMPRESS=YES");
  100.     if(node->xfh_PackMode > MAX_PACK_MODE){
  101.       SPrintF(buf,"PACKMODE=%s",(char *)&node->xfh_PackerID);
  102.     }else{
  103.       SPrintF(buf,"PACKMODE=%s.%ld",(char *)&node->xfh_PackerID,node->xfh_PackMode);
  104.     }
  105.     set_option(glob, buf);
  106.   }else{
  107.     set_option(glob, "AUTOCOMPRESS=NO");
  108.   }
  109.   
  110.   return TRUE;    /* Never fail. */
  111. }
  112. #undef bool2string
  113.  
  114. static BOOL SetConfigSem(glb glob, struct XFHNode *node){
  115.  
  116.   node->xfh_LowMemory = glob->stepdown;
  117.   
  118.   node->xfh_AutoPack  = glob->autocompress;
  119.  
  120.   if(glob->packmode){
  121.     strncpy((char *)&node->xfh_PackerID, glob->packmode, sizeof(ULONG));
  122.     if(glob->packmode[4] == '.'){   /* ToDo: This is rather unsafe... */
  123.       node->xfh_PackMode = atoi(&glob->packmode[5]);
  124.     }else{
  125.       node->xfh_PackMode = MAX_PACK_MODE+1;
  126.     }
  127.   }else{
  128.     node->xfh_PackerID = 0L;
  129.     node->xfh_PackMode = MAX_PACK_MODE+1;
  130.   }
  131.  
  132.   node->xfh_RootLock = c2b(glob->xrootlock);
  133.   
  134.   return TRUE;   /* Never fail. */
  135. }
  136.  
  137.  
  138. /* this prototype of function will either create a new node and add it to */
  139. /* the semaphore, or, if it already exists, read the configuration from it. */
  140. /* You will call this function:
  141. /* a) after initialization, to read or create your node */
  142. /* b) when you receive a CTRL_F, to read your node */
  143. /**/
  144. /* your main loop will look like this:
  145.   portsignal = 1L << myport->mp_SigBit;
  146.  
  147.   recsignal = Wait(portsignal | SIGBREAKF_CTRL_F);
  148.  
  149.   if (recsignal & SIGBREAKF_CTRL_F) UpdateXFHNode();
  150.   if (recsignal & portsignal)
  151.   {
  152.     while (msg = GetMsg(myport))
  153.     {
  154.       ...usual msg processing...
  155.     }
  156.   }
  157. */
  158. BOOL UpdateXFHNode(glb glob){
  159.   struct XFHSemaphore *sem;
  160.   struct XFHNode *node;
  161.   BOOL succ;
  162.   
  163.   if(sem = GetSemaphore(glob)){
  164.     if(node=(struct XFHNode *)FindName(&sem->xfh_DeviceList,glob->devname)){
  165.       debug(("Reading config from semaphore.\n"));
  166.       succ = ReadConfigSem(glob, node);
  167.     }
  168.     else if(node = AllocMem(sizeof(struct XFHNode)
  169.                    + strlen(glob->devname) + 1,MEMF_CLEAR|MEMF_PUBLIC)){
  170.       debug(("Creating new entry in semaphore.\n"));
  171.       node->xfh_Length = sizeof(struct XFHNode);
  172.       node->xfh_Node.ln_Name = (UBYTE *)(node + 1);
  173.       strcpy(node->xfh_Node.ln_Name,glob->devname);
  174.       succ = SetConfigSem(glob, node);
  175.  
  176.       node->xfh_Handler = glob->dosport;
  177.       AddTail(&sem->xfh_DeviceList,(struct Node *)node);
  178.     }else{
  179.       debug(("Unable to create XFHNode entry!!!.\n"));
  180.       OUTOFMEM;
  181.       succ = FALSE;
  182.     }
  183.     ReleaseSemaphore((struct SignalSemaphore *)sem);
  184.   }else{
  185.    debug(("Unable to obtain semaphore!!!\n"));
  186.     succ = FALSE;
  187.   }
  188.   return succ;
  189. }
  190.  
  191.  
  192. ULONG guisigmask(glb glob){
  193.    return GUISIGMASK;
  194. }
  195.  
  196.  
  197. /* End of gui.c */
  198.